package com.msb.blob;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;

/**
 * 解决同样的问题的更高效的方法，使用AtomXXX类
 * AtomXXX类本身方法都是原子性的，但不能保证多个方法连续调用是原子性的
 */
public class T9 {
    AtomicInteger count = new AtomicInteger(0);
    void m() {
        for (int i =0; i< 10000; i++)
            count.incrementAndGet(); //count++
    }

    public static void main(String[] args) {
        T9 t = new T9();
        List<Thread> threads = new ArrayList<Thread>();

        for (int i = 0; i< 10; i++) {
            threads.add(new Thread(t::m, "thread-" + i));
        }

        threads.forEach((o)->o.start());
        threads.forEach((o)->{
            try {
                o.join();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        });
        System.out.println(t.count);
    }
}
//AtomicInteger:原子性操作的int类型
//incrementAndGet()：原子方法，你可以认为它是加了synchronized的，当然它内部实现不是用
//synchronized的而是用系统相当于底层的实现来去完成的；它的效率要比synchronized高很多
